<?php

namespace app\api\controller\wanlshop;

use addons\wanlshop\library\WanlSdk\Common;
use app\common\controller\Api;
use fast\Tree;
use think\Db;

/**
 * WanlShop产品接口
 */
class Product extends Api
{
    protected $noNeedLogin = ['lists', 'goods', 'drawer', 'comment', 'likes', 'stock'];
    protected $noNeedRight = ['*'];

    protected $excludeFields = "";

    /**
     * 获取商品列表 1.0.3升级 隐藏查询结果 1.0.4升级 错误查询
     *
     * @ApiSummary  (WanlShop 产品接口获取商品列表)
     * @ApiMethod   (GET)
     *
     */
    public function lists($type = 'goods')
    {
        //设置过滤方法
        $this->request->filter(['strip_tags']);
        // 判断业务类型
        if($type === 'goods'){
            $goodsModel  = model('app\api\model\wanlshop\Goods');
            $w["wr_wanlshop_goods.id"] = ["<>","873"];
        }else if($type === 'groups'){
            $goodsModel  = model('app\api\model\wanlshop\groups\Goods');
            $w = "1 = 1";
        }
        // 生成搜索条件
        list($where, $sort, $order) = $this->buildparams('title,category.name',false); // 查询标题 和类目字段  ！！！！！！排除已下架//-------------------------------------------
        // 查询数据
        $list = $goodsModel
            ->with(['shop','category'])
            ->where($where)
            ->where($w)
            ->where('goods.status', 'normal')
            ->order($sort, $order)
            ->paginate();
        foreach ($list as $row) {
            $row->getRelation('shop')->visible(['city', 'shopname', 'state', 'isself']);
            $row->getRelation('category')->visible(['id','pid','name']);
            $row->isLive = model('app\api\model\wanlshop\Live')->where(['shop_id' => $row['shop_id'], 'state' => 1])->field('id')->find();
        }
        $this->success('返回成功', $list);
    }

    /**
     * 搜索获取品牌列表
     *
     * @ApiSummary  (WanlShop 产品接口获取品牌列表)
     * @ApiMethod   (GET)
     *
     */
    public function drawer($type = 'goods')
    {
        //设置过滤方法
        $this->request->filter(['strip_tags']);
        $search = $this->request->request("search"); // 查询商品品牌
        $id = $this->request->request("category_id"); // 查询类目品牌
        // 判断业务类型
        if($type === 'goods'){
            $goodsModel  = model('app\api\model\wanlshop\Goods');
        }else if($type === 'groups'){
            $goodsModel  = model('app\api\model\wanlshop\groups\Goods');
        }
        $brandModel = model('app\api\model\wanlshop\Brand');
        $attributeModel  = model('app\api\model\wanlshop\Attribute');

        // 1.0.8升级  获取父级类目属性
        $category_id = null;
        $attribute_ids = null;
        $tree = Tree::instance();
        $tree->init(collection(model('app\index\model\wanlshop\Category')->select())->toArray(), 'pid');

        // 直接查询类目
        if($id){
            $category_id = $id;
            $attribute_ids = $tree->getParentsIds($id, true);
        }
        // 通过商品类目查询
        if($search){
            $ids = [];
            foreach ($goodsModel->where('title', 'like', '%'.$search.'%')->select() as $row) {
                $ids[] = $row['category_id'];
            }
            $ids = array_flip($ids);
            $category_ids = '';
            foreach ($ids as $key => $value){
                $category_ids .= implode(',', $tree->getParentsIds($key, true)).',';
            }
            $category_id = array_keys($ids);
            $attribute_ids = array_keys(array_flip(explode(',', rtrim($category_ids, ','))));
        }
        // 返回数据
        $this->success('返回成功', [
            'brand' => $brandModel
                ->where('category_id', 'in', $category_id)
                ->where('status','normal')
                ->field('name')
                ->select(),
            'attribute' => $attributeModel
                ->where('category_id', 'in', $attribute_ids)
                ->where('status','normal')
                ->field('name,value')
                ->select()
        ]);
    }

    /**
     * 猜你喜欢
     *
     * @ApiSummary  (WanlShop 猜你喜欢)
     * @ApiMethod   (GET)
     *
     * @param string $pages 页面ID
     * @param string $category_id 类目ID
     */
    public function likes()
    {
        $pages = $this->request->request('pages'); //不同页面不同排序,goods只获得与当前产品相同类目,index获得排名靠前的,user随意获取
        $category_id = $this->request->request('cid');
        // 判断来源
        if($pages == 'index'){
            $sort = 'payment';
        }else if($pages == 'user'){
            $sort = 'comment';
        }else if($pages == 'cart'){
            $sort = 'views';
        }else if($pages == 'goods'){
            $sort = 'weigh';
        }else{
            $sort = 'like';
        }
        $uuid = $this->request->server('HTTP_UUID');
        if(!isset($uuid)){
            $charid = strtoupper(md5($this->request->header('user-agent').$this->request->ip()));
            $uuid = substr($charid, 0, 8).chr(45).substr($charid, 8, 4).chr(45).substr($charid,12, 4).chr(45).substr($charid,16, 4).chr(45).substr($charid,20,12);
        }
        // 统计
        $record = model('app\api\model\wanlshop\Record')->where(['uuid'=>$uuid]);
        // 获取上架商品 1.0.3升级
        $where['status'] = 'normal';
        //如果没有
        if($record->count() == 0){
            if($category_id){
                $category_pid = model('app\api\model\wanlshop\Category')->get($category_id);
                $array = model('app\api\model\wanlshop\Category')
                    ->where(['pid' => $category_pid['pid']])
                    ->select();
                $cid = [];
                foreach ($array as $value) {
                    $cid[] = $value['id'];
                }
//				$where['category_id'] = ['in',$cid];
                // 合并条件
                $where['category_id'] = ['not in', array_merge(config('oem.CategoryIdNotLikePrefix'), $cid)];

            }
            $goods = model('app\api\model\wanlshop\Goods')
                ->where($where)
                ->orderRaw('rand()')
                ->field('id,shop_id,title,image,flag,price,views,sales,comment,praise,like')
                ->paginate();
        }else{
            $like_cat = array_count_values($record->column('category_pid')); //喜欢的类目
            $like_goods_cat = array($record->order('views', 'desc')->find()['category_pid']); //喜欢产品的类目
            arsort($like_cat); //排序
            $like_cat_top = array_slice(array_keys($like_cat),0,5); //排名前5
            $category_pid = array_intersect($like_cat_top,$like_goods_cat); //是否包含喜欢的产品类目
            // 如果包含输入产品类目,如果不包含输出排名第一的
            if($category_pid){
                $category_pid = array_slice($category_pid,0,1)[0];
            }else{
                $category_pid = $like_cat_top[0];
            }
            // 查询指定
            if($category_id){
                $category_pid = model('app\api\model\wanlshop\Category')->get($category_id)['pid'];
            }
            //查询下级类目
            $array = model('app\api\model\wanlshop\Category')
                ->where(['pid' => $category_pid])
                ->select();
            $cid = [];
            foreach ($array as $value) {
                $cid[] = $value['id'];
            }
//			$where['category_id'] = ['in',$cid];
            // 合并条件
            $where['category_id'] = ['not in', array_merge(config('oem.CategoryIdNotLikePrefix'), $cid)];
            // 查询父ID下所有商品
            $goods = model('app\api\model\wanlshop\Goods')
                ->where($where)
                ->orderRaw('rand()')
                ->field('id,shop_id,title,image,flag,price,views,sales,comment,praise,like')
                ->paginate();
        }
        foreach ($goods as $row) {
            $row->shop->visible(['state','shopname']);
            $row->isLive = model('app\api\model\wanlshop\Live')->where(['shop_id' => $row['shop_id'], 'state' => 1])->field('id')->find();
        }
        $this->success('返回成功', $goods);
    }

    /**
     * 获取商品详情
     *
     * @ApiSummary  (WanlShop 产品接口、浏览+1、获取UUID生成访问记录)
     * @ApiMethod   (GET)
     *
     * @param string $id 商品ID
     */
    public function goods()
    {
        //设置过滤方法
        $this->request->filter(['strip_tags']);
        $id = $this->request->request("id");
        // 是否传入商品ID
        $id ? $id : ($this->error(__('非正常访问')));
        // 加载商品模型
        $goodsModel = model('app\api\model\wanlshop\Goods');
        // 查询商品
        $goods = $goodsModel
            ->where(['id' => $id])
            ->field('id,category_id,discounts,shop_category_id,brand_id,freight_id,shop_id,title,image,images,flag,content,category_attribute,activity_type,price,sales,payment,comment,praise,moderate,negative,like,views,status')
            ->find();
        // 浏览+1 & 报错
        if($goods && $goods['status'] == 'normal'){
            //  return json($goods['category_id']);
            // 查询类目
            $goods["category"] = db("wanlshop_category")->where("id",$goods['category_id'])->field('id,pid,name')->find();
// 			$goods->category->visible(['id','pid','name']);
            // 查询优惠券
            $goods['coupon'] = [];//$this->queryCoupon($goods['id'], $goods['shop_id'], $goods['shop_category_id'], $goods['price']);
            // 查询是否关注
            $goods['follow'] = $this->isfollow($id);
            // 查询品牌
            $goods->brand->visible(['name']);
            // 查询SKU
//			$sku_list = db("wanlshop_goods_sku")->where(['goods_id'=>$goods['id'], 'stock'=>['>',0], 'state'=> ['=',0]])->field('id,thumbnail,difference,price,market_price,stock,state,weigh,sn,sales')->select();
//            foreach ($sku_list as $k => $sk){
//                $priceStr = (string)$sk["price"];
//                $discountStr = (string)$goods["discounts"];
//                $sku_list[$k]["pv"] = bcmul($priceStr, $discountStr / 100, 2);
//            }
//            $goods['sku'] = $sku_list;
            $goods['sku'] = $goods->sku;
            // 查询SPU
            $goods['spu'] = $goods->spu;
            // 查询直播状态
            $goods['isLive'] = model('app\api\model\wanlshop\Live')->where(['shop_id' => $goods['shop_id'], 'state' => 1])->field('id')->find();
            // 查询评论
            $goods['comment_list'] = $goods->comment_list;
            // 获取店铺详情
            $goods->shop->visible(['shopname','service_ids','avatar','city','like','score_describe','score_service','score_logistics']);
            // 查询快递 运费ID 商品重量 邮递城市 商品数量
            $goods['freight'] = $this->freight($goods['freight_id']);
            // 查询促销
            $goods['promotion'] = $id; //--下个版本更新--
            // 店铺推荐
            $goods['shop_recommend'] = $goodsModel
                ->where(['shop_id' => $goods['shop_id'], 'status' => 'normal']) //还可以使用 , 'flag' => 'recommend'
                ->field('id,title,image,price')
                ->limit(3)
                ->select();
            // 查询促销
            $goods['pv'] = bcmul($goods["price"], $goods["discounts"] / 100, 2);
            // 浏览+1
            $goods->setInc('views');
            // 写入访问日志
            $this->addbrowse($goods);
            // 返回结果
            $this->success('返回成功', $goods);
        }else{
            $this->error(__('对不起当前商品不存在或已下架！'));
        }
    }

    /**
     * 实时查询库存
     *
     * @ApiSummary  (WanlShop 实时查询库存)
     * @ApiMethod   (GET)
     *
     * @param string $sku_id  SKU
     */
    public function stock($sku_id = '')
    {
        $redis = Common::redis();
        $sku = model('app\api\model\wanlshop\GoodsSku')->get($sku_id);
        $sku_key = 'goods_'.$sku['goods_id'].'_'.$sku['id'];
        // 获取缓存数量
        $llen = $redis->llen("{$sku_key}");
        if(!$llen){
            for ($i = 0; $i < $sku['stock']; $i ++) {
                $redis->lpush("{$sku_key}", 1);
            }
        }
        $this->success('查询成功', $redis->llen("{$sku_key}"));
    }

    /**
     * 是否关注商品
     *
     * @ApiSummary  (WanlShop 保存浏览记录)
     * @ApiMethod   (GET)
     *
     * @param string $goods  商品数据
     */
    public function isfollow($goods_id ='')
    {
        $data = false;
        if ($this->auth->isLogin()) {
            $follow = model('app\api\model\wanlshop\GoodsFollow')
                ->where([
                    'user_id' => $this->auth->id,
                    'goods_id' => $goods_id,
                    'goods_type' => 'goods'
                ])
                ->count();
            $data = $follow == 0 ? false : true; //关注
        }
        return $data;
    }

    /**
     * 保存浏览记录
     *
     * @ApiSummary  (WanlShop 保存浏览记录)
     * @ApiMethod   (GET)
     *
     * @param string $goods  商品数据
     */
    public function addbrowse($goods =[])
    {
        //保存浏览记录
        $uuid = $this->request->server('HTTP_UUID');
        if(!isset($uuid)){
            $charid = strtoupper(md5($this->request->header('user-agent').$this->request->ip()));
            $uuid = substr($charid, 0, 8).chr(45).substr($charid, 8, 4).chr(45).substr($charid,12, 4).chr(45).substr($charid,16, 4).chr(45).substr($charid,20,12);
        }
        $recordModel = model('app\api\model\wanlshop\Record');
        $goods_type = 'goods';
        $record = $recordModel
            ->where([
                'uuid' => $uuid,
                'goods_id' => $goods['id'],
                'goods_type' => $goods_type
            ])
            ->find();
        if($record){
            $update['id'] = $record['id'];
            if ($this->auth->isLogin()) {
                $update['user_id'] = $this->auth->id;
            }
            $update['views'] = $record['views'] + 1;
            $record->update($update);
        }else{
            if ($this->auth->isLogin()) {
                $recordModel->user_id = $this->auth->id;
            }
            $recordModel->uuid = $uuid;
            $recordModel->goods_id = $goods['id'];
            $recordModel->goods_type = $goods_type;
            $recordModel->shop_id = $goods['shop_id'];
            if($goods['category'] == null){
                $recordModel->category_id = $goods['category_id'];
                $recordModel->category_pid = 0;
            }else{
                $recordModel->category_id = $goods['category']['id'];
                $recordModel->category_pid = $goods['category']['pid'];
            }
            $recordModel->ip = $this->request->ip();
            $recordModel->save();
        }
    }

    /**
     * 关注商品
     *
     * @ApiSummary  (WanlShop 关注或取消商品)
     * @ApiMethod   (POST)
     *
     * @param string $id 商品ID
     */
    public function follow()
    {
        //设置过滤方法
        $this->request->filter(['strip_tags']);
        if ($this->request->isPost()) {
            $id = $this->request->post("id");
            // 是否传入商品ID
            $id ? $id : ($this->error(__('非正常访问')));
            // 加载商品模型
            $goodsModel = model('app\api\model\wanlshop\Goods');
            $goodsFollowModel = model('app\api\model\wanlshop\GoodsFollow');
            $data = [
                'user_id' => $this->auth->id,
                'goods_id' => $id,
                'goods_type' => 'goods'
            ];
            if($goodsFollowModel->where($data)->count() == 0){
                $goodsFollowModel->save($data);
                $goodsModel->where(['id' => $id])->setInc('like'); //喜欢+1
                $follow = true;
            }else{
                $goodsFollowModel->where($data)->delete();
                $goodsModel->where(['id' => $id])->setDec('like'); //喜欢-1
                $follow = false;
            }
            $this->success('返回成功', $follow);
        }
        $this->error(__('非正常访问'));
    }

    /**
     * 收藏夹列表 1.0.8升级
     */
    public function collect($type = 'goods')
    {
        $followIds = [];
        $followModel = model('app\api\model\wanlshop\GoodsFollow');
        // 判断业务类型
        if($type === 'goods'){
            $goodsModel = model('app\api\model\wanlshop\Goods');
            $field = 'id, shop_id, title, image, views, price, sales, payment, like';
        }else if($type === 'groups'){
            $goodsModel = model('app\api\model\wanlshop\groups\Goods');
            $field = 'id, shop_id, title, image, views, price, sales, payment, like, is_ladder, people_num';
        }
        // 获取收藏夹IDS
        foreach ($followModel->where(['user_id' => $this->auth->id, 'goods_type' => $type])->select() as $row) {
            // 排除不存在商品
            if($goodsModel->get($row['goods_id'])){
                $followIds[] = $row['id'];
            }
        }
        // 按条件查询
        $list = $followModel
            ->where('id', 'in', $followIds)
            ->field('goods_id')
            ->paginate();
        foreach ($list as $row) {
            $row['goods'] = $goodsModel
                ->where(['id' => $row['goods_id']])
                ->field($field)
                ->find();
        }
        $this->success('返回成功', $list);
    }

    /**
     * 足迹列表 1.0.8升级
     */
    public function footprint($type = 'goods')
    {
        $footprintIds = [];
        $recordModel = model('app\api\model\wanlshop\Record');
        // 判断业务类型
        if($type === 'goods'){
            $goodsModel = model('app\api\model\wanlshop\Goods');
        }else if($type === 'groups'){
            $goodsModel = model('app\api\model\wanlshop\groups\Goods');
        }
        // 1.0.8升级  通过uuid查询足迹
        $uuid = $this->request->server('HTTP_UUID');
        if(!isset($uuid)){
            $charid = strtoupper(md5($this->request->header('user-agent').$this->request->ip()));
            $uuid = substr($charid, 0, 8).chr(45).substr($charid, 8, 4).chr(45).substr($charid,12, 4).chr(45).substr($charid,16, 4).chr(45).substr($charid,20,12);
        }
        // 获取足迹IDS
        $record = $recordModel->where(['uuid' => $uuid, 'goods_type' => $type])->select();
        foreach ($record as $row) {
            // 排除不存在商品
            if($goodsModel->get($row['goods_id'])){
                $footprintIds[] = $row['id'];
            }
        }
        // 按条件查询
        $list = $recordModel
            ->where('id', 'in', $footprintIds)
            ->field('goods_id, createtime')
            ->order('createtime', 'desc')
            ->paginate();
        foreach ($list as $row) {
            $row['goods'] = $goodsModel
                ->where(['id' => $row['goods_id']])
                ->field('id, image, title, price, payment')
                ->find();
        }
        $this->success('返回成功', $list);
    }

    /**
     * 查询用户指定店铺浏览记录
     *
     * @ApiSummary  (查询用户指定店铺浏览记录 1.0.2升级)
     * @ApiMethod   (POST)
     *
     * @param string $shop_id 店铺ID
     */
    public function getBrowsingToShop()
    {
        //设置过滤方法
        $this->request->filter(['strip_tags']);
        if($this->request->isPost()){
            $shop_id = $this->request->post('shop_id');
            $shop_id ? '':($this->error(__('Invalid parameters')));
            $list = model('app\api\model\wanlshop\Record')
                ->where(['shop_id' => $shop_id, 'user_id' => $this->auth->id])
                ->group('goods_id')
                ->field('goods_id, createtime')
                ->select();
            foreach ($list as $row) {
                // 1.0.8升级
                $row->goods ? $row->goods->visible(['id', 'image', 'title', 'price']) : false;
            }
            $this->success(__('发送成功'), $list);
        }
        $this->error(__('非法请求'));
    }

    /**
     * 获取商品评论
     *
     * @ApiSummary  (WanlShop 获取商品下所有评论)
     * @ApiMethod   (POST)
     *
     * @param string $tag 评论分类
     * @param string $id  商品ID
     * @param string $list_rows  每页数量
     * @param string $page  当前页
     */
    public function comment()
    {
        //设置过滤方法
        $this->request->filter(['strip_tags']);
        $id = $this->request->request("id");
        $tag = $this->request->request('tag');
        // 是否传入商品ID
        $id ? $id : ($this->error(__('非正常访问')));
        // 加载商品模型
        $goodsCommentModel = model('app\api\model\wanlshop\GoodsComment')->order('createtime desc');
        //查询tag 评价:0=好评,1=中评,2=差评
        if($tag){
            if($tag == 'good'){
                $where['state'] = 0;
            }else if($tag == 'pertinent'){
                $where['state'] = 1;
            }else if($tag == 'poor'){
                $where['state'] = 2;
            }else if($tag == 'figure'){
                $where['images'] = ['neq', ''];//有图
            }else{
                $where['tag'] = $tag;
            }
        }
        $where['goods_id'] = $id;
        $where['order_type'] = 'goods';
        $comment['comment'] = $goodsCommentModel
            ->with(['user'])
            ->where($where)
            ->paginate();
        // $comment['tag'] = array_count_values($goodsCommentModel->where(['goods_id'=>$id])->limit(100)->column('tag')); //统计热词
        foreach ($comment['comment'] as $row) {
            $row->getRelation('user')->visible(['username','nickname','avatar']);
        }
        $goods = model('app\api\model\wanlshop\Goods')
            ->where(['id' => $id])
            ->find();
        // 1.1.6升级 兼容php7.4
        if($goods){
            $comment['statistics'] = [
                'rate'     => $goods['comment'] == 0 ? '0' : bcmul(bcdiv($goods['praise'], $goods['comment'], 2), 100, 2),
                'total'    => $goods['comment'],
                'good'     => $goods['praise'],
                'pertinent'=> $goods['moderate'],
                'poor'     => $goods['negative'],
                'figure'   => $goodsCommentModel->where(['goods_id' => $id])->where('images','neq', '')->count()
            ];
        }else{
            $comment['statistics'] = [];
        }

        $this->success('返回成功', $comment);
    }

    /**
     * 获取运费模板和子类 内部方法 -----下个版本完善------
     * @param string $id  运费ID
     * @param string $weigh  商品重量
     * @param string $city  邮递城市
     * @param string $number  商品数量
     */
    private function freight($id = null, $weigh = 0, $city = '北京', $number = 1)
    {
        // 运费模板
        $data = model('app\api\model\wanlshop\ShopFreight')->where('id', $id)->field('id,delivery,isdelivery,name,valuation')->find();
        $data['price'] = 0;
        // 是否包邮:0=自定义运费,1=卖家包邮
        if($data['isdelivery'] == 0){
            // 获取地址编码 1.1.0升级
            $list = model('app\api\model\wanlshop\ShopFreightData')
                ->where([
                    ['EXP', Db::raw('FIND_IN_SET('.model('app\common\model\Area')->get(['name' => $city])->id.', citys)')],
                    'freight_id' => $id
                ])
                ->find();
            // 查询是否存在运费模板数据
            if(!$list){
                $list = model('app\api\model\wanlshop\ShopFreightData')->get(['freight_id' => $id]);
            }

            // 计价方式:0=按件数,1=按重量,2=按体积
            if($data['valuation'] == 0){
                if($number <= $list['first']){
                    $price = $list['first_fee'];
                }else{
                    $price = ceil(($number - $list['first']) / $list['additional']) * $list['additional_fee'] + $list['first_fee'];
                }
            }else{
                $weigh = $weigh * $number; // 订单总重量
                if($weigh <= $list['first']){ // 如果重量小于等首重，则首重价格
                    $price = $list['first_fee'];
                }else{
                    $price = ceil(($weigh - $list['first']) / $list['additional']) * $list['additional_fee'] + $list['first_fee'];
                }
            }
            $data['price'] = $price;
        }
        return $data;
    }

    /**
     * 查询我的优惠券 内部方法 (跨段存在登录问题，无法解决，暂时复制进来这个方法)
     *
     * @param string $goods_id 商品ID
     * @param string $shop_id 店铺ID
     * @param string $shop_category_id 分类ID
     * @param string $price 价格
     */
    private function queryCoupon($goods_id = null, $shop_id = null, $shop_category_id = null, $price = null)
    {
        $user_coupon = [];
        if ($this->auth->isLogin()) {
            foreach (model('app\api\model\wanlshop\CouponReceive')->where([
                'user_id' => $this->auth->id,
                'shop_id' => $shop_id,
                'limit' => ['<=', intval($price)],
                'state' => '1'
            ])->select() as $row) {
                $user_coupon[$row['coupon_id']] = $row;
            }
        }
        // 开始查询
        $list = [];
        $goods_id = explode(",",$goods_id);
        $shop_category_id = explode(",",$shop_category_id);
        //要追加一个排序 选出一个性价比最高的
        foreach (model('app\api\model\wanlshop\Coupon')->where([
            'shop_id' => $shop_id,
            'limit' => ['<=', intval($price)]
        ])->select() as $row) {
            // 筛选出还未开始的
            if(!($row['pretype'] == 'fixed' && (strtotime($row['startdate']) >= time() || strtotime($row['enddate']) < time()))){
                //追加字段
                $row['choice'] = false;
                // 检查指定的键名是否存在于数组中
                if(array_key_exists($row['id'], $user_coupon)){
                    $row['invalid'] = 0; // 强制转换优惠券状态
                    $row['id'] = $user_coupon[$row['id']]['id'];
                    $row['state'] = true;
                }else{
                    $row['state'] = false;
                }
                // 排除失效优惠券
                if($row['invalid'] == 0){
                    // 高级查询，比较数组，返回交集如果和原数据数目相同则加入
                    if($row['rangetype'] == 'all'){
                        $list[] = $row;
                    }
                    if($row['rangetype'] == 'goods' && count($goods_id) == count(array_intersect($goods_id, explode(",",$row['range'])))){
                        $list[] = $row;
                    }
                    // 1.1.0升级
                    if($row['rangetype'] == 'category'){
                        // 判断优化全类目是否在商品类目中，explode(',', $row['range'])[0] 目的向前兼容
                        if( in_array(explode(',', $row['range'])[0], $shop_category_id) ){
                            $list[] = $row;
                        }
                    }
                }
            }
        }
        return $list;
    }



    /**
     * 生成查询所需要的条件,排序方式
     * @param mixed   $searchfields   快速查询的字段
     * @param boolean $relationSearch 是否关联查询
     * @return array
     */
    protected function buildparams($searchfields = null, $relationSearch = null)
    {
        $searchfields = is_null($searchfields) ? $this->searchFields : $searchfields;
        $relationSearch = is_null($relationSearch) ? $this->relationSearch : $relationSearch;
        // 获取传参
        $search = $this->request->get("search", '');
        $filter = $this->request->get("filter", '');
        $op = $this->request->get("op", '', 'trim');
        $sort = $this->request->get("sort", !empty($this->model) && $this->model->getPk() ? $this->model->getPk() : 'id');
        $order = $this->request->get("order", "DESC");
        $filter = (array)json_decode($filter, true);
        $op = (array)json_decode($op, true);
        $filter = $filter ? $filter : [];
        $where = [];
        $tableName = '';
        if ($relationSearch) {
            if (!empty($this->model)) {
                $name = \think\Loader::parseName(basename(str_replace('\\', '/', get_class($this->model))));
                $name = $this->model->getTable();
                $tableName = $name . '.';
            }
            $sortArr = explode(',', $sort);
            foreach ($sortArr as $index => & $item) {
                $item = stripos($item, ".") === false ? $tableName . trim($item) : $item;
            }
            unset($item);
            $sort = implode(',', $sortArr);
        }


        // 判断是否需要验证权限
        // if (!$this->auth->match($this->noNeedLogin)) {
        //     $where[] = [$tableName . 'user_id', 'in', $this->auth->id];
        // }

        if ($search) {
            $searcharr = is_array($searchfields) ? $searchfields : explode(',', $searchfields);
            foreach ($searcharr as $k => &$v) {
                $v = stripos($v, ".") === false ? $tableName . $v : $v;
            }
            unset($v);
            $arrSearch = [];
            foreach (explode(" ", $search) as $ko) {
                $arrSearch[] = '%'.$ko.'%';
            }
            $where[] = [implode("|", $searcharr), "LIKE", $arrSearch];
        }
        // 历遍所有
        if (array_key_exists('category_id', $filter)) {
            $filter['category_id'] = implode(',', array_column(Tree::instance()->init(model('app\api\model\wanlshop\Category')->all())->getChildren($filter['category_id'], true), 'id'));
        }
        foreach ($filter as $k => $v) {
            $sym = isset($op[$k]) ? $op[$k] : '=';
            if (stripos($k, ".") === false) {
                $k = $tableName . $k;
            }
            $v = !is_array($v) ? trim($v) : $v;
            $sym = strtoupper(isset($op[$k]) ? $op[$k] : $sym);
            switch ($sym) {
                case '=':
                case '<>':
                    $where[] = [$k, $sym, (string)$v];
                    break;
                case 'LIKE':
                case 'NOT LIKE':
                case 'LIKE %...%':
                case 'NOT LIKE %...%':
                    $where[] = [$k, trim(str_replace('%...%', '', $sym)), "%{$v}%"];
                    break;
                case '>':
                case '>=':
                case '<':
                case '<=':
                    $where[] = [$k, $sym, intval($v)];
                    break;
                case 'FINDIN':
                case 'FINDINSET':
                case 'FIND_IN_SET':
                    $where[] = "FIND_IN_SET('{$v}', " . ($relationSearch ? $k : '`' . str_replace('.', '`.`', $k) . '`') . ")";
                    break;
                case 'IN':
                case 'IN(...)':
                case 'NOT IN':
                case 'NOT IN(...)':
                    $where[] = [$k, str_replace('(...)', '', $sym), is_array($v) ? $v : explode(',', $v)];
                    break;
                case 'BETWEEN':
                case 'NOT BETWEEN':
                    $arr = array_slice(explode(',', $v), 0, 2);
                    if (stripos($v, ',') === false || !array_filter($arr)) {
                        continue 2;
                    }
                    //当出现一边为空时改变操作符
                    if ($arr[0] === '') {
                        $sym = $sym == 'BETWEEN' ? '<=' : '>';
                        $arr = $arr[1];
                    } elseif ($arr[1] === '') {
                        $sym = $sym == 'BETWEEN' ? '>=' : '<';
                        $arr = $arr[0];
                    }
                    $where[] = [$k, $sym, $arr];
                    break;
                case 'RANGE':
                case 'NOT RANGE':
                    $v = str_replace(' - ', ',', $v);
                    $arr = array_slice(explode(',', $v), 0, 2);
                    if (stripos($v, ',') === false || !array_filter($arr)) {
                        continue 2;
                    }
                    //当出现一边为空时改变操作符
                    if ($arr[0] === '') {
                        $sym = $sym == 'RANGE' ? '<=' : '>';
                        $arr = $arr[1];
                    } elseif ($arr[1] === '') {
                        $sym = $sym == 'RANGE' ? '>=' : '<';
                        $arr = $arr[0];
                    }
                    $where[] = [$k, str_replace('RANGE', 'BETWEEN', $sym) . ' time', $arr];
                    break;
                case 'LIKE':
                case 'LIKE %...%':
                    $where[] = [$k, 'LIKE', "%{$v}%"];
                    break;
                case 'NULL':
                case 'IS NULL':
                case 'NOT NULL':
                case 'IS NOT NULL':
                    $where[] = [$k, strtolower(str_replace('IS ', '', $sym))];
                    break;
                default:
                    break;
            }
        }
        $where = function ($query) use ($where) {
            foreach ($where as $k => $v) {
                if (is_array($v)) {
                    call_user_func_array([$query, 'where'], $v);
                } else {
                    $query->where($v);
                }
            }
        };
        return [$where, $sort, $order];
    }

}
